<!DOCTYPE html>
<html lang="zh">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>自定义指令</title>
</head>

<!-- 引入 Vue 插件 -->
<script src="./js/vue@3.5.13.js"></script>
<body>
    <div id="app">
        <h1 v-color="'green'">这是一个标题</h1>
        <h1 v-rap="'我是一个rapper'"></h1>
    </div>
    <script>
        const { createApp } = Vue
        const app = createApp({
            setup(){ return {  } }
        })

        // 实现一个 color 指令 - 传入不同的颜色, 给标签设置文字颜色
        // v-if v-show v-for
        app.directive('color',{
            // 钩子函数
            mounted(el,binding){
                // el：获取的 DOM 对象 -> document.querySelector("h1")
                el.style.color = binding.value
            }
        })
        // 实现一个自定义指令，v-rap ，动态文字渲染
        app.directive('rap',{
            // 钩子函数
            mounted(el,binding){
                // 通过 binding 动态改变文字内容
                el.innerText = binding.value
            }
        })

        app.mount("#app") // 挂载容器
    </script>
</body>
</html>